

AVR32

32-bit Microcontrollers and Application Processors



Introduction to AVR Assembly Language Programming I February 2009



Everywhere You Are®

# **Introduction to AVR Assembly Language Programming**

### **READING**



The AVR Microcontroller and Embedded Systems using Assembly and C) by Muhammad Ali Mazidi, Sarmad Naimi, and Sepehr Naimi

Chapter 0: Introduction To Computing

Section 0.1: Number Systems and Appendix A "Number Systems" at the end of this document

Section 0.2: Digital Primer

Chapter 1: The AVR Microcontroller: History and Features

Section 1.1: Microcontrollers and Embedded Processors

Chapter 2: AVR Architecture and Assembly Language Programming

Section 2.5: AVR Data Format and Directives

Section 2.6: Introduction to AVR Assembly Programming

Section 2.7: Assembling An AVR Program

## **SOURCE MATERIAL**

These are some of the sources I used to develop the material used in the lecture series.

- 1. Reduced Instruction Set Computer: <a href="http://en.wikipedia.org/wiki/Load-store\_architecture">http://en.wikipedia.org/wiki/Load-store\_architecture</a>
- 2. Atmel AVR Assembler User Guide <a href="http://www.atmel.com/dyn/resources/prod\_documents/doc1022.pdf">http://www.atmel.com/dyn/resources/prod\_documents/doc1022.pdf</a>
- 3. Atmel AVR: <a href="http://en.wikipedia.org/wiki/Atmel\_AVR">http://en.wikipedia.org/wiki/Atmel\_AVR</a>
- 4. AVR Quick Reference Guide: <a href="http://www.atmel.com/dyn/resources/prod\_documents/doc4064.pdf">http://www.atmel.com/dyn/resources/prod\_documents/doc4064.pdf</a>
- 5. ATmega328P Summary (26 pages) <a href="http://www.atmel.com/dyn/resources/prod\_documents/8161S.pdf">http://www.atmel.com/dyn/resources/prod\_documents/8161S.pdf</a>
- 6. ATmega328P (448 pages) http://www.atmel.com/dyn/resources/prod\_documents/doc8161.pdf
- 7. 8-bit AVR Instruction Set (155 pages) <a href="http://www.atmel.com/dyn/resources/prod\_documents/doc0856.pdf">http://www.atmel.com/dyn/resources/prod\_documents/doc0856.pdf</a>

# **CONTENTS**

| Reading                                               |    |
|-------------------------------------------------------|----|
| Source Material                                       | 3  |
| Contents                                              |    |
| What is an Embedded System?                           | 5  |
| What is an Arduino                                    | 6  |
| What is a CSULB Shield                                | 7  |
| The Building Blocks of an Embedded System             | 8  |
| What is a Program?                                    | 9  |
| How is Machine Code Related to Assembly Language?     | 10 |
| Design Example                                        | 11 |
| Development Steps                                     | 13 |
| Help                                                  | 14 |
| Appendix A – Number Systems                           | 16 |
| Introduction                                          | 16 |
| Positional Notation (Positive Real Integers)          | 16 |
| Introduction to Binary System                         | 16 |
| Base Eight and Base Sixteen                           | 17 |
| Conversion From Base 10 to a Given Radix (or Base)    | 18 |
| Nomenclature                                          | 20 |
| Binary Addition                                       | 20 |
| Octal Addition                                        | 21 |
| Hexadecimal Addition                                  | 21 |
| Binary Multiplication                                 | 22 |
| Binary Division                                       | 22 |
| Complements and Negative Numbers OR Adding a Sign Bit | 23 |
| Character Codes OR Non-Numeric Information            | 26 |
| Appendix B – ATmega328P Instruction Set               | 32 |
| Appendix C – Arduino Proto-Shield Schematic           | 35 |

## WHAT IS AN EMBEDDED SYSTEM?

- An embedded system is an electronic system
  that contains at least one controlling device,
  i.e. "the brain", but in such a way that it is
  hidden from the end user. That is, the
  controller is embedded so far in the system
  that usually users don't realize its presence.
- Embedded systems perform a dedicated function.



# What is the Controlling Device?

| EE Course | Technology                                                                           | Tools                               |
|-----------|--------------------------------------------------------------------------------------|-------------------------------------|
| EE201     | Discrete Logic                                                                       | Boolean Algebra                     |
| EE301     | Field Programmable Gate Array (FPGA), Application-Specific Integrated Circuit (ASIC) | HDL (typically VHDL or Verilog)     |
| EE346     | Microcontroller                                                                      | Program (typically C++ or Assembly) |
| EE443     | System on a Chip (SoC)                                                               | System Level Design Language        |

## WHAT IS AN ARDUINO



Arduino is an open-source electronics PCB containing a microcontroller and the things needed to support it: Power Supply,
 Communications, Reset Button, Clock, and Connectors for adding Sensors and Actuators in the physical world.

• Using an Arduino you can develop interactive objects, taking inputs from a variety of switches or sensors, and controlling a

variety of lights, motors, and other physical outputs.

• The Arduino consists of two parts; the hardware and the software.

We will be using the Arduino Uno which contains an ATmega328P
 8 bit microcontroller.

 We will be using AVR Studio to develop the software for the Arduino in place of the Arduino IDE and associated Scripting Language.

## WHAT IS A CSULB SHIELD

- The CSULB Shield was designed to meet the educational objectives of EE 346.
- The shield works with the <u>Arduino</u> Uno, Duemilanove (rev 2009b), and Mega Microcontroller Boards.





- CSULB Shield Specifications
  - o Input
    - 8 Toggle Switches
    - General Purpose Push Button
    - Reset Button
  - o Output
    - 8 Discrete Red LEDs
    - 3 Discrete Green LEDs
    - 1 7-Segment Display

## THE BUILDING BLOCKS OF AN EMBEDDED SYSTEM

### What is an Input and Output Peripheral Device?

A device attached to a controlling mechanism, for example a computer, yet is not actually part of the controlling mechanism,
 and whose operation is functionally dependent upon the controlling mechanism.

How do you design this controlling mechanism?

- If you control peripherals using Discrete Electronics or a Programmable Logic Device (PLD) such as an FPGA or ASIC, then the control is in hardware (EE201, EE301).
- If you control peripherals using a Microcontroller then the control is in software (EE346 and EE444), implemented by a
   Program.
- If you control peripheral using a System on a Chip (SoC) then the control may be in software and/or hardware (EE443).



Figure 1.2: Embedded system block diagram using a microcontroller.

## WHAT IS A PROGRAM?

- The *Program* is a "very specific list of instructions" to the computer.
- The process of "creating the program" is where much of an electrical engineer's time is spent.
- The program is often referred to as
   Software, while the physical system
   components are called Hardware. Software
   held within non-volatile memory is called

   Firmware.
- Software design is all about creating patterns of 0's and 1's in order to get the computer to do what we want. These 0's and 1's are known as *Machine Code*.



```
0010 0111 0000 0000 \rightarrow 1110 1111 0001 1111 \rightarrow 1011 1001 0000 0111 \rightarrow 1011 1001 0001 1000 1011 1001 0000 0100 \rightarrow 1011 0000 0111 0110 \rightarrow 1011 1000 0111 0101 \rightarrow 1100 1111 1111 1101
```

• The architecture of the processer (or computer) within a microcontroller is unique as are the *Machine Code Instructions* it understands.

```
0010 0111 0000 0000
1110 1111 0001 1111
```

The list of Machine Code Instructions understood by a Microcontroller is known as the Machine Language.

## HOW IS MACHINE CODE RELATED TO ASSEMBLY LANGUAGE?

## Machine Code (The language of the machine)

 Binary Code (bit sequence) that directs the computer to carry out (execute) a pre-defined operation.

```
0010 0111 0000 0000
1110 1111 0001 1111
1011 1001 0000 0111
1011 1001 0001 1000
```

## **Assembly Language**

- A computer language where there is a one-to-one correspondence between a symbolic (assembly language instruction) and a machine code instruction.
- The language of the machine in human readable form

```
clr r16
ser r17
out DDRC, r16
out PORTC, r17
```

## Corollary

• Specific to a single computer or class of computers (non-portable)



## **ANATOMY OF AN ASSEMBLY INSTRUCTION**

# Sample Code Segment

| Machine Code        | Assembly Code |                |
|---------------------|---------------|----------------|
| Binary              | Нех           |                |
| 0010 0111 0000 0000 | 0x2700        | clr r16        |
| 1110 1111 0001 1111 | 0xEF1F        | ser r17        |
| 1011 1001 0000 0111 | 0xB907        | out DDRC, r16  |
| 1011 1001 0001 1000 | 0xB918        | out PORTC, r17 |

- The **Operation Code** or **Opcode** for short, is a mnemonic that tells the CPU what instruction is to be executed. In the sample code above that would be clr (clear), ser (set register), and out (output to I/O location). One or more operands follow the Opcode.
- The **Operand(s)** specify the location of the data that is to be operated on by the CPU. In many cases it is the Arithmetic Logic Unit (ALU) that performs the specified operation.

## **DESIGN EXAMPLE**

Write an Assembly Program to turn a light on and off with a switch. A similar program was used in the design of <a href="https://example.com/The-Wake-up-Machine">The Wake-up Machine</a>.



## **DEVELOPMENT STEPS**



## ASSEMBLY AND MICROCONTROLLER OVERVIEW



### HELP

### $0010\ 0111\ 0000\ 0000_2 = 2700_{16} = clr\ r16...$

An Important part of this course is understanding the Design and Language of "The Computer."

The computer implements the *classical* digital gate you learned in your Digital Logic class (EE201) in software with instructions like and, or, and eor.

You are also going to have to seamlessly move from binary to hexadecimal and back again (i.e., Number Systems).

Computer programs move data through Registers, so a working knowledge of Flip-Flops and Registers is also an important foundational part of this class.

Finally, instead of designing with gates (EE201) you will be designing with code. So you will need to review Programming concepts like: data transfer (assignment expressions), arithmetic and logic operators, control transfer (branching and looping), and bit and bit test operators that you leaned in your programming class (CECS174 or CECS100).

The good news is that help is available in Chapter 0: "Introduction to Computing" of your textbook, the supplemental reading provided at the beginning of this document, the web, and Appendix A - Number Systems.

## APPENDIX A - NUMBER SYSTEMS

### Numbers and Their Computer Representation

### Introduction

Base 10 result of ten fingers

Arabic symbols 0-9, India created Zero and Positional Notation

Other Systems: Roman Numerals: essentially additive, Importance of Roman Numeral lies in whether a symbol precedes or follows another symbol. Ex. IV = 4 versus VI = 6. This was a very clumsy system for arithmetic operations.

## POSITIONAL NOTATION (POSITIVE REAL INTEGERS)

Fractional numbers will not be considered but it should be noted that the addition of said would be a simple and logical addition to the theory presented.

The value of each digit is determined by its position. Note pronunciation of 256 "Two Hundred and Fifty Six?

Ex.  $256 = 2*10^2 + 5*10^1 + 6*10^0$ 

Generalization to any base or radix

Base or Radix = Number of different digit which can occur in each position in the number system.

 $N = A_n r^n + A_{n-1} r^{n-1} + ... + A_1 r^1 + A_0 r^0$  (or simple  $A_1 r + A_0$ )

## INTRODUCTION TO BINARY SYSTEM

The operation of most digital devices is binary by nature, either they are on or off.

Examples: Switch, Relay, Tube, Transistor, and TTL IC

Thus it is only logical for a digital computer to in base 2.

Note: Future devices may not have this characteristic, and this is one of the reasons the basics and theory are important. For they add flexibility to the system.

In the Binary system there are only 2 states allowed; 0 and 1 (FALSE or TRUE, OFF or ON)

```
Example: Most Significant Bit

↓ High Order Bit

1010 = 1*2³ + 0*2² + 1*2¹ + 0*2⁰ = 10₁₀

↑ Least Significant Bit

Low Order Bit

↑ Denotes Base 10

Usually implied by context
```

Bit = One Binary Digit (0 or 1)

This positional related equation also gives us a tool for converting from a given radix to base 10 - in this example Binary to Decimal.

### BASE EIGHT AND BASE SIXTEEN

Early in the development of the digital computer Von Neuman realized the usefulness of operating in intermediate base systems such as base 8 (or Octal)

By grouping 3 binary digits or bits one octal digit is formed. Note that  $2^3 = 8$ 

Binary to Octal Conversion Table

 $\begin{array}{c} 2^{2}2^{1}2^{0} \\ 000 = 0 \\ 001 = 1 \\ 010 = 2 \\ 011 = 3 \\ 100 = 4 \\ 101 = 5 \\ 110 = 6 \\ 111 = 7 \end{array}$ 

Symbols (not numbers) 8 and 9 are not used in octal.

Example: 100 001 010 110

4 1 2  $6_8 = 4*8^3 + 1*8^2 + 2*8^1 + 6*8^0 = 2134$ 

This is another effective way of going from base 2 to base 10

Summary: Base 8 allows you to work in the language of the computer without dealing with large numbers of ones and zeros. This is made possible through the simplicity of conversion from base 8 to base 2 and back again.

In microcomputers groupings of 4 bits (as opposed to 3 bits) or base 16 (24) is used. Originally pronounced Sexadecimal, base 16 was quickly renamed Hexadecimal (this really should be base 6).

### Binary to Hex Conversion Table

```
2<sup>3</sup>2<sup>2</sup>2<sup>1</sup>2<sup>0</sup>
0000 = 0
0001 = 1
0010 = 2
0011 = 3
0100 = 4
0101 = 5
0110 = 6
0111 = 7
1000 = 8
1001 = 9
1010 = A
1011 = B
1100 = C
1101 = D
1110 = E
1111 = F
```

In Hex <u>Symbols</u> for 10 to 15 are borrowed from the alphabet. This shows how relative numbers really are or in other words, they truly are just symbols.

Example: 1000 0101 0110  $8 5 6_{16} = 8*16^2 + 5*16^1 + 6*16^0 = 2134$ 

It is not as hard to work in base 16 as you might think, although it does take a little practice.

## CONVERSION FROM BASE 10 TO A GIVEN RADIX (OR BASE)

Successive Division is best demonstrated by an example

To get the digits in the right order let them fall to the right.

For this example:  $43_{10} = 101011_2$  Quick Check (Octal)  $101 \ 011 = 5*8 + 3 = 43_{10}$ 

Another example: Convert 43<sub>10</sub> from decimal to Octal

For this example:  $43_{10} = 53_8$  Quick Check (Octal)  $5*8 + 3 = 43_{10}$ 

GENERALIZATION OF THE PROCEDURE OR WHY IT WORKS

Where r = radix, N = number, A = remainder, and n = the number of digits in radix r for number N. Division is normally done in base 10.

Another way of expressing the above table is:

$$N = r^*N_1 + A_0$$

$$N_1 = r^*N_2 + A_1$$

$$N_2 = r^*N_3 + A_2$$

•

$$N_{n-1} = r^*N_n + A_{n-1}$$

$$N_n = r^*0 + A_n$$

or (now for the slight of hand)

$$N = r^*(r^*N_2 + A_1) + A_0$$
 substitute  $N_1$ 

$$N = r^2N_2 + rA_1 + A_0$$
 multiply r through equation

$$N = r^2(r^*N_3 + A_2) + rA_1 + A_0$$
 substitute  $N_2$ 

:

$$N = A_n r^n + A_{n-1} r^{n-1} + ... + A_1 r^1 + A_0 r^0$$
 ...

## Nomenclature

Bit = 1 binary digit

Byte = 8 bits

Nibble = one half byte = 4 bits Word = Computer Dependent

## **Binary Arithmetic**

### **BINARY ADDITION**

Binary addition is performed similar to decimal addition using the following binary addition rules:

0 + 0 = 0

0 + 1 = 1

1 + 0 = 1

1 + 1 = 10 (0 with a carry of 1)

## Examples:

## OCTAL ADDITION

Octal addition is also performed similar to decimal addition except that each digit has a range of 0 to 7 instead of 0 to 9.

| Problem @ | $21_{10} + 10_{10} = 31_{10}$ | $45_{10} + 54_{10} = 99_{10}$ | $3_{10} + 7_{10} = 10_{10}$ |  |
|-----------|-------------------------------|-------------------------------|-----------------------------|--|
|           | 258                           | 558                           | 38                          |  |
|           | + 128                         | + 668                         | + 78                        |  |
|           | 378                           | 143 <sub>8</sub>              | 128                         |  |
| Check @   | $3*8^1 + 7*8^0$               | $1*8^2 + 4*8^1 + 3*8^0$       | $1*8^1 + 2*8^0$             |  |
|           | $3*8 + 7*1 = 31_{10}$         | $64 + 32 + 3 = 99_{10}$       | $8 + 2 = 10_{10}$           |  |

## **HEXADECIMAL ADDITION**

Hex addition is also performed similar to decimal addition except that each digit has a range of 0 to 15 instead of 0 to 9.

| $21_{10} + 10_{10} = 31_{10}$          | $45_{10} + 54_{10} = 99_{10}$                                                                                          | $3_{10} + 7_{10} = 10_{10}$                           |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| 15 <sub>16</sub>                       | 2D <sub>16</sub>                                                                                                       | 3 <sub>16</sub>                                       |
| + 0A <sub>16</sub>                     | + 36 <sub>16</sub>                                                                                                     | + 7 <sub>16</sub>                                     |
| 1F <sub>16</sub>                       | 63 <sub>16</sub>                                                                                                       | A <sub>16</sub> (not 10)                              |
| 1*16 <sup>1</sup> + 15*16 <sup>0</sup> | $6*16^1 + 3*16^0$                                                                                                      | 10*16 <sup>0</sup>                                    |
| 16 + 15 = 31 <sub>10</sub>             | $96 + 3 = 99_{10}$                                                                                                     | 10 <sub>10</sub>                                      |
|                                        | $   \begin{array}{r}     15_{16} \\     + 0A_{16} \\ \hline     1F_{16} \\   \end{array} $ $    1*16^{1} + 15*16^{0} $ | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ |

## BINARY MULTIPLICATION

| Decimal                 | Binary                                 |
|-------------------------|----------------------------------------|
| 11 <sub>10</sub>        | 10112                                  |
| x 13 <sub>10</sub>      | x 1101 <sub>2</sub>                    |
| 33 <sub>10</sub>        | 10112                                  |
| <b>11</b> <sub>10</sub> | 0000 <sub>2</sub><br>1011 <sub>2</sub> |
|                         | 10112                                  |
| 143 <sub>10</sub>       |                                        |
|                         | 100011112                              |
| Check ©                 | 8*16 <sup>1</sup> + 15*16 <sup>0</sup> |
|                         | $128 + 15 = 143_{10}$                  |

## **BINARY DIVISION**

| Decimal                              |         | Binary                                |
|--------------------------------------|---------|---------------------------------------|
| 21 <sub>10</sub>                     |         | 101012                                |
| 5 <sub>10</sub> 105 <sub>10</sub> 10 | 1012    | 1101001 <sub>2</sub><br>101           |
| 05<br>05                             |         | 110<br>101                            |
| 00                                   |         | 101<br>101                            |
|                                      | •       | 000                                   |
|                                      | Check © | 1*16 <sup>1</sup> + 5*16 <sup>0</sup> |
|                                      |         | $16 + 5 = 21_{10}$                    |

Practice arithmetic operations by making problems up and then checking your answers by converting them back to base 10 via different bases (i.e., 2, 8, and 16).

How a computer performs arithmetic operations is a much more involved subject and has not been dealt with in this section.

### COMPLEMENTS AND NEGATIVE NUMBERS OR ADDING A SIGN BIT

Addition, Multiplication, and Division is nice but what about subtraction and negative numbers? From grade school you have learned that subtraction is simply the addition of a negative number. Mathematicians along with engineers have exploited this principle along with modulo arithmetic — a natural outgrowth of adders of finite width — to allow computers to operate on negative numbers without adding any new hardware elements to the arithmetic logic unit (ALU).

#### SIGN MAGNITUDE

Here is a simple solution, just add a sign bit. To implement this solution in hardware you will need to create a subtractor; which means more money.

sign magnitude

Example: -2 = 1 0010<sub>2</sub>

#### **ONES COMPLEMENT**

Here is a solution that is a little more complex. Add the sign bit and invert each bit making up the magnitude — simply change the 1's to 0's and the 0's to 1's.

sign magnitude

Example: -2 = 1 1101<sub>2</sub>

To subtract in 1's complement you simply add the sign and magnitude bits letting the last carry bit (from the sign) fall into the **bit bucket**, and then add 1 to the answer. Once again let the last carry bit fall into the bit bucket. The bit bucket is possible due to the physical size of the adder.

Although you can now use your hardware adder to subtract numbers, you now need to add 1 to the answer. This again means adding hardware. Compounding this problem, ones complement allows two numbers to equal 0 (schizophrenic zero).

### **TWOS COMPLEMENT**

Here is a solution that is a little more complex to set up, but needs no adjustments at the end of the addition. There are two ways to take the twos complement of a number.

Method 1 = Take the 1's complement and add 1

Method 2 = Move from right to left until a 1 is encountered then invert.

$$\begin{array}{ccc} 0 \ 0010_2 & \text{start} & \ @ \ 2_{10} \\ & 0_2 & \text{no change} \\ & 10_2 & \text{no change but one is encountered} \\ & 110_2 & \text{invert} & \ @ \ change \ 0 \ to \ 1 \\ & 1110_2 & \text{invert} & \ @ \ change \ 0 \ to \ 1 \\ & 1\ 1110_2 & \text{invert} & \ @ \ change \ 0 \ to \ 1 \\ \end{array}$$

Subtraction in twos complement is the same as addition. No adjustment is needed, and twos complement has **no schizophrenic zero** although it does have an additional negative number (see How It Works).

Examples:

Problem 
$$●$$
 33<sub>10</sub> - 19<sub>10</sub> = 14<sub>10</sub> 69<sub>10</sub> - 84<sub>10</sub> = -15<sub>10</sub>

$$0 \ 100001_2 \qquad 0 \ 1000101_2$$
+ 1 101101<sub>2</sub> + 1 0101100<sub>2</sub>

$$0 \ 001110_2 \qquad 1 \ 1110001_2$$
Check  $●$  convert to convert back to sign magnitude intermediate base intermediate base  $0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2$ 

$$0 \ 0 \ 0 \ 0 \ 0 \ 0 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.001111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.00111_2 = 0.0011_2 = 0.0011_2 = 0.00111_2 = 0.00111_2 = 0.0011_2 = 0.0011_2 = 0.0011_2 = 0.0011_2 = 0.0011_2 = 0.0011_2 = 0$$

#### WHY IT WORKS

Real adders have a finite number of bits, which leads naturally to modulo arithmetic — the bit bucket.



### **OVERFLOW**

With arithmetic now reduced to going around in circles, positive numbers can add up to negative and vice-versa. Two tests provide a quick check on whether or not an "Overflow" condition exists.

Test 1 = If the two numbers are negative and the answer is positive, an overflow has occurred.

Test 2 = If the two number are positive and the answer is negative, an overflow has occurred.

If computers were calculators and the world was a perfect place, we would be done. But they are not and so we continue by looking at a few real world problems and their solutions.

### CHARACTER CODES OR NON-NUMERIC INFORMATION

#### **DECIMAL NUMBER PROBLEM**

Represent a Decimal Numbers in a Binary Computer. A binary representation of a decimal number, a few years ago, might have been "hard wired" into the arithmetic logic unit (ALU) of the computer. Today it, more likely than not, is simply representing some information that is naturally represented in base 10, for example your student ID.

#### SOLUTION

In this problem, ten different digits need to be represented. Using 4 bits 2<sup>4</sup> or 16 combinations can be created. Using 3 bits 2<sup>3</sup> or 8 combinations can be created. Thus 4 bits will be required to represent one Decimal Digit. It should here be pointed out how 16 combinations can be created from 4 bits (0000 - 1111) while the largest numeric value that can be represented is 15. The reason that the highest numeric value and the number of combinations are different, is due to zero (0) being one of the combinations. This difference points up the need to always keep track of wetter or not you are working zero or one relative and what exactly you are after — a binary number or combinations.

The most common way of representing a decimal number is named Binary Coded Decimal (BCD). Here each binary number corresponds to its decimal equivalent, with numbers larger than 9 simply not allowed. BCD is also known as an 8-4-2-1 code since each number represents the respective weights of the binary digits. In contrast the Excess-3 code is an unweighted code used in earlier computers. Its code assignment comes from the corresponding BCD code plus 3. The Excess-3 code had the advantage that by complementing each digit of the binary code representation of a decimal digit (1's complement), the 9's complement of that digit would be formed. The following table lists each decimal digit and its BCD and Excess-3 code equivalent representation. I have also included the negative equivalent of each decimal digit encoded using the Excess-3 code. For instance, the complement of 0100 (1 decimal) is 1011, which is 8 decimal. You can find more decimal codes on page 18 of "Digital Design" by M. Morris Mano (course text).

| Binary Coded<br>Decimal (BCD) |                           |                  | Excess-        | 3                 |
|-------------------------------|---------------------------|------------------|----------------|-------------------|
| Decimal<br>Digit              | Binary<br>Code<br>8-4-2-1 | Decimal<br>Digit | Binary<br>Code | 9's<br>Compliment |
| 0                             | 0000                      | N/A              | 0000           | 1111              |
| 1                             | 0001                      | N/A              | 0001           | 1110              |
| 2                             | 0010                      | N/A              | 0010           | 1101              |
| 3                             | 0011                      | 0                | 0011           | 1100              |
| 4                             | 0100                      | 1                | 0100           | 1011              |

| 5   | 0101 | 2   | 0101 | 1010 |
|-----|------|-----|------|------|
| 6   | 0110 | 3   | 0110 | 1001 |
| 7   | 0111 | 4   | 0111 | 1000 |
| 8   | 1000 | 5   | 1000 | 0111 |
| 9   | 1001 | 6   | 1001 | 0110 |
| N/A | 1010 | 7   | 1010 | 0101 |
| N/A | 1011 | 8   | 1011 | 0100 |
| N/A | 1100 | 9   | 1100 | 0011 |
| N/A | 1101 | N/A | 1101 | 0010 |
| N/A | 1110 | N/A | 1110 | 0001 |
| N/A | 1111 | N/A | 1111 | 0000 |
|     |      |     |      |      |
|     |      |     |      |      |

#### **ALPHANUMERIC CHARACTER PROBLEM**

Represent Alphanumeric data (lower and upper case letters of the alphabet (a-z, A-Z), digital numbers (0-9), and special symbols (carriage return, line feed, period, etc.).

#### SOLUTION

To represent the upper and lower case letters of the alphabet, plus ten numbers, you need at least 62 (2x26+10) unique combinations. Although a code using only six binary digits providing 2<sup>6</sup> or 64 unique combinations would work, only 2 combinations would be left for special symbols. On the other hand a code using 7 bits provides 2<sup>7</sup> or 128 combinations, which provides more than enough room for the alphabet, numbers, and special symbols. So who decides which binary combinations correspond to what character. Here there is no "best way." About thirty years ago IBM came out with a new series of computers which used 8 bits to store one character (2<sup>8</sup> = 256 combinations), and devised the Extended Binary-Coded Decimal Interchange Code (EBCDIC pronounced ep-su-dec) for this purpose. Since IBM had a near monopoly on the computer field, at that time, the other computer makers refused to adopt EBCDIC, and that is how the 7bit American Standard Code for Information Interchange (ASCII) came into existence. ASCII has now been adopted by virtually all micro-computer and mini-computer manufacturers. The table below shows a partial list of the ASCII code. Page 23 of the text lists all 128 codes with explanations of the control characters.

| DEC | HEX | CHAR | DEC | HEX | CHAR |
|-----|-----|------|-----|-----|------|
| 32  | 20  |      | 64  | 40  | @    |
| 33  | 21  | !    | 65  | 41  | Ä    |
| 34  | 22  | "    | 66  | 42  | В    |
| 35  | 23  | #    | 67  | 43  | С    |
| 36  | 24  | \$   | 68  | 44  | D    |
| 37  | 25  | %    | 69  | 45  | E    |
| 38  | 26  | &    | 70  | 46  | F    |
| 39  | 27  | í    | 71  | 47  | G    |
| 40  | 28  | (    | 72  | 48  | Н    |

| 41 | 29 | ) | 73 | 49 | I |
|----|----|---|----|----|---|
| 42 | 2A | * | 74 | 4A | J |
| 43 | 2B | + | 75 | 4B | K |
| 44 | 2C | , | 76 | 4C | L |
| 45 | 2D | - | 77 | 4D | M |
| 46 | 2E | * | 78 | 4E | N |
| 47 | 2F | / | 79 | 4F | 0 |
| 48 | 30 | 0 | 80 | 50 | Р |
| 49 | 31 | 1 | 81 | 51 | Q |
| 50 | 32 | 2 | 82 | 52 | R |
| 51 | 33 | 3 | 83 | 53 | S |
| 52 | 34 | 4 | 84 | 54 | T |
| 53 | 35 | 5 | 85 | 55 | U |
| 54 | 36 | 6 | 86 | 56 | V |
| 55 | 37 | 7 | 87 | 57 | W |
| 56 | 38 | 8 | 88 | 58 | Χ |
| 57 | 39 | 9 | 89 | 59 | Υ |
| 58 | 3A | : | 90 | 5A | Z |
| 59 | 3B | ; | 91 | 5B | [ |
| 60 | 3C | < | 92 | 5C | \ |
| 61 | 3D | = | 93 | 5D | ] |
| 62 | 3E | > | 94 | 5E | ۸ |
| 63 | 3F | ? | 95 | 5F | _ |
|    |    |   |    |    |   |

The word "string" is commonly used to describe a sequence of characters stored via their numeric codes — like ASCII).

Although ASCII requires only 7 bits, the standard in computers is to use 8 bits, where the leftmost bit is set to 0. This allows you to code another 128 characters (including such things as Greek letters), giving you an *extended character set*, simply by letting the leftmost bit be a 1. This can also lead to a computer version of the tower of Babel. Alternatively, the leftmost bit can be used for detecting errors when transmitting characters over a telephone line. Which brings us to our next problem.

#### **S**YNTHESIS

Although ASCII solves the communication problem between English speaking computers, what about Japanese, Chinese, or Russian computers which have different, and in all these examples, larger alphabets?

#### **COMMUNICATION PROBLEM**

Binary information may be transmitted serially (one bit at a time) through some form of communication medium such as a telephone line or a radio wave. Any external noise introduced into the medium can change bit values from 1 to 0 or visa versa.

#### SOLUTION

The simplest and most common solution to the communication problem involves adding a *parity bit* to the information being sent. The function of the parity bit is to make the total number of 1's being sent either odd (odd parity) or even (even parity). Thus, if any odd number of 1's were sent but an even number of 1's received, you know an error has occurred. The table below illustrates the appropriate parity bit (odd and even) that would be appended to a 4-bit chunk of data.

#### SYNTHESIS

What happens if two binary digits change bit values? Can a system be devised to not only detect errors but to identify and correct the bit(s) that have changed? One of the most common error-correcting codes was developed by R.W. Hamming. His solution, known as a Hamming code, can be found in a very diverse set of places from a Random Access Memory (RAM) circuit to a Spacecraft telecommunications link. For more of error correcting codes read pages 299 to 302 of the text.

Although detecting errors is nice, preventing them from occurring is even better. Which of course brings us to our next problem.

#### SHAFT ENCODER PROBLEM

As a shaft turns, you need to convert its radial position into a binary coded digital number.

#### SOLUTION

The type of coder which will be briefly described below converts a shaft position to a binary-coded digital number. A number of different types of devices will perform this conversion; the type described is representative of the devices now in use, and it should be realized that more complicated coders may yield additional accuracy. Also, it is generally possible to convert a physical position into an electric analog-type signal and then convert this signal to a digital system. In general, though, more direct and accurate coders can be constructed by eliminating the intermediate step of converting a physical position to an analog electric signal. The Figure below illustrates a coded-segment disk which is coupled to the shaft.



The shaft encoder can be physically realized using electro-mechanical (brush) or electro-optical technology. Assuming an electro-optical solution, the coder disk is constructed with bands divided into transparent segments (the shaded areas) and opaque segments (the unshaded areas). A light source is put on one side of the disk, and a set of four photoelectric cells on the other side, arranged so that one cell is behind each band of the coder disk. If a transparent segment is between the light source and a light-sensitive cell, a 1 output will result; and if an opaque area is in front of the photoelectric cell, there will be a O output.

There is one basic difficulty with the coder illustrated: if the disk is in a position where the output number is changing from 011 to 100, or in any position where several bits are changing value, the output signal may become ambiguous. As with any physically realized device, no matter how carefully it is made, the coder will have erroneous outputs in several positions. If this occurs when 011 is changing to 100, several errors are possible; the value may be read as 111 or 000, either of which is a value with considerable errors. To circumvent this difficulty, engineers use a "Gray," or "unit distance," code to form the coder disk (see previous Figure). In this code, 2 bits never change value in successive coded binary numbers. Using a Gray coded disk, a 6 may be read as 7, or a 4 as 5, but larger errors will not be made. The Table below shows a listing of a 4-bit Gray code.

| Decimal | Gray Code |  |
|---------|-----------|--|
| 0       | 0000      |  |
| 1       | 0001      |  |
| 2       | 0011      |  |
| 3       | 0010      |  |
| 4       | 0110      |  |
| 5       | 0111      |  |
| 6       | 0101      |  |
| 7       | 0100      |  |
| 8       | 1100      |  |
| 9       | 1101      |  |
| 10      | 1111      |  |
| 11      | 1110      |  |
| 12      | 1010      |  |
| 13      | 1011      |  |
| 14      | 1001      |  |
| 15      | 1000      |  |
|         |           |  |

#### **SYNTHESIS**

Gray code is used in a multitude of application other than shaft encoders. For example, CMOS circuits draw the most current when they are switching. If a large number of circuits switch at the same time unwelcome phenomena such as "Ground Bounce" and "EMI Noise" can result. If the transistors are switching due to some sequential phenomena (like counting), then these unwelcome visitors can be minimized by replacing a weighted binary code by a Gray code.

If the inputs to a binary machine are from an encoder using a Gray code, each word must be converted to conventional binary or binary-coded decimal bit equivalent. How can this be done? Before you can answer this question, you will need to learn about Boolean Algebra — what a coincidence, that's the topic of the next Section.

# APPENDIX B – ATMEGA328P INSTRUCTION SET<sup>1</sup>

| Mnemonics           | Operands           | Description                                                            | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Flags        | #Clocks |
|---------------------|--------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------|
| ARITHMETIC AND I    | LOGIC INSTRUCTIONS | S                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |         |
| ADD                 | Rd, Rr             | Add two Registers                                                      | Rd ← Rd + Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,C,N,V,H    | 1       |
| ADC                 | Rd, Rr             | Add with Carry two Registers                                           | $Rd \leftarrow Rd + Rr + C$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,C,N,V,H    | 1       |
| ADIW                | Rdl,K              | Add Immediate to Word                                                  | Rdh:Rdl ← Rdh:Rdl + K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Z,C,N,V,S    | 2       |
| SUB                 | Rd, Rr             | Subtract two Registers                                                 | Rd ← Rd - Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,C,N,V,H    | 1       |
| SUBI                | Rd, K              | Subtract Constant from Register                                        | Rd ← Rd - K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,C,N,V,H    | 1       |
| SBC                 | Rd, Rr             | Subtract with Carry two Registers                                      | Rd ← Rd - Rr - C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Z,C,N,V,H    | 1       |
| SBCI                | Rd, K              | Subtract with Carry Constant from Reg.                                 | Rd ← Rd - K - C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Z,C,N,V,H    | 1       |
| SBIW                | RdI,K              | Subtract Immediate from Word                                           | Rdh:Rdl ← Rdh:Rdl - K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Z,C,N,V,S    | 2       |
| AND                 | Rd, Rr             | Logical AND Registers                                                  | Rd ← Rd • Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,N,V        | 1       |
| ANDI                | Rd, K              | Logical AND Register and Constant                                      | Rd ← Rd • K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,N,V        | 1       |
| OR                  | Rd, Rr             | Logical OR Registers                                                   | Rd ← Rd v Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,N,V        | 1       |
| ORI                 | Rd, K              | Logical OR Register and Constant                                       | Rd ← Rd v K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,N,V        | 1       |
| EOR                 | Rd, Rr             | Exclusive OR Registers                                                 | Rd ← Rd ⊕ Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,N,V        | 1       |
| COM                 | Rd                 | One's Complement                                                       | Rd ← 0xFF – Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Z,C,N,V      | 1       |
| NEG                 | Rd                 | Two's Complement                                                       | Rd ← 0x00 – Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Z,C,N,V,H    | 1       |
| SBR                 | Rd,K               | Set Bit(s) in Register                                                 | Rd ← Rd v K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,N,V        | 1       |
| CBR                 | Rd,K               | Clear Bit(s) in Register                                               | $Rd \leftarrow Rd \cdot (0xFF - K)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Z,N,V        | 1       |
| INC                 | Rd                 | Increment                                                              | Rd ← Rd + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,N,V        | 1       |
| DEC                 | Rd                 | Decrement                                                              | Rd ← Rd – 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z,N,V        | 1       |
| TST                 | Rd                 | Test for Zero or Minus                                                 | Rd ← Rd • Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z.N.V        | 1       |
| CLR                 | Rd                 | Clear Register                                                         | Rd ← Rd ⊕ Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Z,N,V        | 1       |
| SER                 | Rd                 | Set Register                                                           | Bd ← 0xFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | None         | 1       |
| MUL                 | Rd, Rr             | Multiply Unsigned                                                      | R1:R0 ← Rd x Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Z,C          | 2       |
| MULS                | Rd, Rr             | Multiply Signed                                                        | R1:R0 ← Rd x Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Z.C          | 2       |
| MULSU               | Rd, Rr             | Multiply Signed with Unsigned                                          | R1:R0 ← Rd x Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Z,C          | 2       |
| FMUL                | Rd, Rr             | Fractional Multiply Unsigned                                           | R1:R0 ← (Rd x Rr) << 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Z,C          | 2       |
| FMULS               | Rd. Rr             | Fractional Multiply Signed                                             | R1:R0 ← (Rd x Rr) << 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Z.C          | 2       |
| FMULSU              | Rd, Rr             | Fractional Multiply Signed with Unsigned                               | R1:R0 ← (Rd x Rr) << 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Z,C          | 2       |
| BRANCH INSTRUC      |                    | Tradicial manery digrical mer driving rea                              | The control of the co | 2,0          |         |
| RJMP                | k                  | Relative Jump                                                          | PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 2       |
| LIMP                | n .                | Indirect Jump to (Z)                                                   | PC ← Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | None         | 2       |
| JMP <sup>(1)</sup>  | k                  | Direct Jump                                                            | PC ← k                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | None         | 3       |
| RCALL               | k                  | Relative Subroutine Call                                               | PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 3       |
| ICALL               |                    | Indirect Call to (Z)                                                   | PC ← Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | None         | 3       |
| CALL <sup>(1)</sup> | k                  | Direct Subroutine Call                                                 | PC ← k                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | None         | 4       |
| RET                 |                    | Subroutine Return                                                      | PC ← STACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | None         | 4       |
| RETI                |                    | Interrupt Return                                                       | PC ← STACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | I            | 4       |
| CPSE                | Rd.Rr              | Compare, Skip if Equal                                                 | if (Rd = Rr) PC ← PC + 2 or 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | None         | 1/2/3   |
| CP                  | Rd,Rr              | Compare, Skip ii Equal                                                 | Rd – Rr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Z, N,V,C,H   | 1       |
| CPC                 | Rd,Rr              | Compare with Carry                                                     | Rd – Rr – C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Z, N,V,C,H   | 1       |
| CPI                 | Rd,K               | Compare Register with Immediate                                        | Rd - K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Z, N,V,C,H   | 1       |
| SBRC                | Rr, b              | Skip if Bit in Register Cleared                                        | if (Rr(b)=0) PC ← PC + 2 or 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | None         | 1/2/3   |
| SBRS                | Rr, b              |                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2/3   |
| SBIC                | P. b               | Skip if Bit in Register is Set<br>Skip if Bit in I/O Register Cleared  | if $(Rr(b)=1) PC \leftarrow PC + 2 \text{ or } 3$<br>if $(P(b)=0) PC \leftarrow PC + 2 \text{ or } 3$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | None         | 1/2/3   |
|                     | P, b               | Skip if Bit in I/O Register Cleared Skip if Bit in I/O Register is Set |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2/3   |
| SBIS<br>BRBS        | s, k               |                                                                        | if (P(b)=1) PC ← PC + 2 or 3<br>if (SREG(e) = 1) then PC← PC+k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | None         | 1/2/3   |
|                     | s, k               | Branch if Status Flag Set                                              | if (SREG(s) = 1) then PC←PC+k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              | 1/2     |
| BREQ                | s, k<br>k          | Branch if Status Flag Cleared Branch if Equal                          | if $(SREG(s) = 0)$ then $PC \leftarrow PC + k + 1$<br>if $(Z = 1)$ then $PC \leftarrow PC + k + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | None<br>None | 1/2     |
| BRNE                | k                  | Branch if Equal  Branch if Not Equal                                   | if $(Z = 1)$ then $PC \leftarrow PC + k + 1$<br>if $(Z = 0)$ then $PC \leftarrow PC + k + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | None<br>None | 1/2     |
|                     |                    | ·                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |         |
| BRCS                | k                  | Branch if Carry Set                                                    | if (C = 1) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRCC                | k                  | Branch if Carry Cleared                                                | if (C = 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRSH                | k                  | Branch if Same or Higher                                               | if (C = 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRLO                | k                  | Branch if Lower                                                        | if (C = 1) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
|                     | k                  | Branch if Minus                                                        | if (N = 1) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRPL                | k                  | Branch if Plus                                                         | if (N = 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRGE                | k                  | Branch if Greater or Equal, Signed                                     | if (N ⊕ V= 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | None         | 1/2     |
| BRLT                | k                  | Branch if Less Than Zero, Signed                                       | if (N ⊕ V= 1) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | None         | 1/2     |
| BRHS                | k                  | Branch if Half Carry Flag Set                                          | if (H = 1) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
|                     | k                  | Branch if Half Carry Flag Cleared                                      | if (H = 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | None         | 1/2     |
| BRHC                |                    | Branch if T Flag Set                                                   | if $(T = 1)$ then $PC \leftarrow PC + k + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | None         | 1/2     |
| BRTS                | k                  |                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |         |
| BRTS<br>BRTC        | k                  | Branch if T Flag Cleared                                               | if $(T = 0)$ then $PC \leftarrow PC + k + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | None         | 1/2     |
| BRTS                |                    |                                                                        | if (T = 0) then PC ← PC + k + 1<br>if (V = 1) then PC ← PC + k + 1<br>if (V = 0) then PC ← PC + k + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | None<br>None | 1/2     |

<sup>&</sup>lt;sup>1</sup> Source: ATmega328P Data Sheet <a href="http://www.atmel.com/dyn/resources/prod\_documents/8161S.pdf">http://www.atmel.com/dyn/resources/prod\_documents/8161S.pdf</a> Chapter 31 Instruction Set Summary

| Mnemonics                     | Operands          | Description                                                 | Operation                                                                                                        | Flags              | #Clocks |  |  |  |
|-------------------------------|-------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------|---------|--|--|--|
| BRIE                          | k                 | Branch if Interrupt Enabled                                 | if (   = 1) then PC ← PC + k + 1                                                                                 | None               | 1/2     |  |  |  |
| BRID                          | k                 | Branch if Interrupt Disabled                                | if (1=0) then PC ← PC + k + 1                                                                                    | None               | 1/2     |  |  |  |
| BIT AND BIT-TEST INSTRUCTIONS |                   |                                                             |                                                                                                                  |                    |         |  |  |  |
| SBI                           | P,b               | Set Bit in I/O Register                                     | I/O(P,b) ← 1                                                                                                     | None               | 2       |  |  |  |
| CBI                           | P,b               | Clear Bit in I/O Register                                   | I/O(P,b) ← 0                                                                                                     | None               | 2       |  |  |  |
| LSL                           | Rd                | Logical Shift Left                                          | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                                                   | Z,C,N,V            | 1       |  |  |  |
| LSR                           | Rd                | Logical Shift Right                                         | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                                                   | Z,C,N,V            | 1       |  |  |  |
| ROL                           | Rd                | Rotate Left Through Carry                                   | $Rd(0)\leftarrow C,Rd(n+1)\leftarrow Rd(n),C\leftarrow Rd(7)$                                                    | Z,C,N,V            | 1       |  |  |  |
| ROR                           | Rd                | Rotate Right Through Carry                                  | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                                               | Z,C,N,V            | 1       |  |  |  |
| ASR                           | Rd                | Arithmetic Shift Right                                      | $Rd(n) \leftarrow Rd(n+1), n=06$                                                                                 | Z,C,N,V            | 1       |  |  |  |
| SWAP                          | Rd                | Swap Nibbles                                                | Rd(30)←Rd(74),Rd(74)←Rd(30)                                                                                      | None               | 1       |  |  |  |
| BSET                          | S                 | Flag Set                                                    | SREG(s) ← 1                                                                                                      | SREG(s)<br>SREG(s) | 1       |  |  |  |
| BCLR                          | Rr, b             | Flag Clear Bit Store from Register to T                     | $SREG(s) \leftarrow 0$<br>$T \leftarrow Rr(b)$                                                                   | T                  | 1       |  |  |  |
| BLD                           | Rd, b             | Bit load from T to Register                                 | Rd(b) ← T                                                                                                        | None               | 1       |  |  |  |
| SEC                           | nu, b             | Set Carry                                                   | C←1                                                                                                              | C                  | 1       |  |  |  |
| CLC                           |                   | Clear Carry                                                 | C←0                                                                                                              | С                  | 1       |  |  |  |
| SEN                           |                   | Set Negative Flag                                           | N ← 1                                                                                                            | N                  | 1       |  |  |  |
| CLN                           |                   | Clear Negative Flag                                         | N ← 0                                                                                                            | N                  | 1       |  |  |  |
| SEZ                           |                   | Set Zero Flag                                               | Z←1                                                                                                              | Z                  | 1       |  |  |  |
| CLZ                           |                   | Clear Zero Flag                                             | Z ← 0                                                                                                            | Z                  | 1       |  |  |  |
| SEI                           |                   | Global Interrupt Enable                                     | I <b>←</b> 1                                                                                                     | 1                  | 1       |  |  |  |
| CLI                           |                   | Global Interrupt Disable                                    | I←0                                                                                                              | 1                  | 1       |  |  |  |
| SES                           |                   | Set Signed Test Flag                                        | S ← 1                                                                                                            | S                  | 1       |  |  |  |
| CLS                           |                   | Clear Signed Test Flag                                      | S ← 0                                                                                                            | S                  | 1       |  |  |  |
| SEV                           |                   | Set Twos Complement Overflow.                               | V ← 1                                                                                                            | V                  | 1       |  |  |  |
| CLV                           |                   | Clear Twos Complement Overflow                              | V ← 0                                                                                                            | V<br>T             | 1       |  |  |  |
| SET<br>CLT                    |                   | Set T in SREG Clear T in SREG                               | T←1<br>T←0                                                                                                       | T                  | 1       |  |  |  |
| SEH                           |                   | Set Half Carry Flag in SREG                                 | H←1                                                                                                              | н                  | 1       |  |  |  |
| CLH                           |                   | Clear Half Carry Flag in SREG                               | H←0                                                                                                              | Н                  | 1       |  |  |  |
| DATA TRANSFER II              | NSTRUCTIONS       |                                                             |                                                                                                                  |                    |         |  |  |  |
| MOV                           | Rd, Rr            | Move Between Registers                                      | Rd ← Rr                                                                                                          | None               | 1       |  |  |  |
| MOVW                          | Rd, Rr            | Copy Register Word                                          | Rd+1:Rd ← Rr+1:Rr                                                                                                | None               | 1       |  |  |  |
| LDI                           | Rd, K             | Load Immediate                                              | Rd ← K                                                                                                           | None               | 1       |  |  |  |
| LD                            | Rd, X             | Load Indirect                                               | $Rd \leftarrow (X)$                                                                                              | None               | 2       |  |  |  |
| LD                            | Rd, X+            | Load Indirect and Post-Inc.                                 | $Rd \leftarrow (X), X \leftarrow X + 1$                                                                          | None               | 2       |  |  |  |
| LD                            | Rd, - X           | Load Indirect and Pre-Dec.                                  | $X \leftarrow X - 1$ , $Rd \leftarrow (X)$                                                                       | None               | 2       |  |  |  |
| LD                            | Rd, Y             | Load Indirect                                               | Rd ← (Y)                                                                                                         | None               | 2       |  |  |  |
| LD                            | Rd, Y+            | Load Indirect and Post-Inc.                                 | $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                                                          | None               | 2       |  |  |  |
| LDD                           | Rd, - Y<br>Rd,Y+q | Load Indirect and Pre-Dec.  Load Indirect with Displacement | $Y \leftarrow Y - 1$ , $Rd \leftarrow (Y)$<br>$Rd \leftarrow (Y + q)$                                            | None<br>None       | 2       |  |  |  |
| LD                            | Rd, Z             | Load Indirect with Displacement  Load Indirect              | Rd ← (Z)                                                                                                         | None               | 2       |  |  |  |
| LD                            | Rd, Z+            | Load Indirect and Post-Inc.                                 | $Rd \leftarrow (Z)$<br>$Rd \leftarrow (Z), Z \leftarrow Z+1$                                                     | None               | 2       |  |  |  |
| LD                            | RdZ               | Load Indirect and Pre-Dec.                                  | Z ← Z - 1, Rd ← (Z)                                                                                              | None               | 2       |  |  |  |
| LDD                           | Rd, Z+q           | Load Indirect with Displacement                             | $Rd \leftarrow (Z + q)$                                                                                          | None               | 2       |  |  |  |
| LDS                           | Rd, k             | Load Direct from SRAM                                       | Rd ← (k)                                                                                                         | None               | 2       |  |  |  |
| ST                            | X, Rr             | Store Indirect                                              | (X) ← Rr                                                                                                         | None               | 2       |  |  |  |
| ST                            | X+, Rr            | Store Indirect and Post-Inc.                                | $(X) \leftarrow \operatorname{Rr}, X \leftarrow X + 1$                                                           | None               | 2       |  |  |  |
| ST                            | - X, Rr           | Store Indirect and Pre-Dec.                                 | $X \leftarrow X - 1$ , $(X) \leftarrow Rr$                                                                       | None               | 2       |  |  |  |
| ST                            | Y, Rr             | Store Indirect                                              | (Y) ← Rr                                                                                                         | None               | 2       |  |  |  |
| ST                            | Y+, Rr            | Store Indirect and Post-Inc.                                | (Y) ← Rr, Y ← Y + 1                                                                                              | None               | 2       |  |  |  |
| ST                            | - Y, Rr           | Store Indirect and Pre-Dec.                                 | Y ← Y - 1, (Y) ← Rr                                                                                              | None               | 2       |  |  |  |
| STD                           | Y+q,Rr            | Store Indirect with Displacement                            | (Y + q) ← Rr                                                                                                     | None               | 2       |  |  |  |
| ST                            | Z, Rr             | Store Indirect                                              | (Z) ← Rr                                                                                                         | None               | 2       |  |  |  |
| ST                            | Z+, Rr<br>-Z, Rr  | Store Indirect and Post-Inc.  Store Indirect and Pre-Dec.   | $(Z) \leftarrow \operatorname{Rr}, Z \leftarrow Z + 1$<br>$Z \leftarrow Z - 1, (Z) \leftarrow \operatorname{Rr}$ | None<br>None       | 2       |  |  |  |
| STD                           | -z, Hr<br>Z+q,Rr  | Store Indirect with Displacement                            | $Z \leftarrow Z - 1$ , $(Z) \leftarrow Rr$<br>$(Z + q) \leftarrow Rr$                                            | None               | 2       |  |  |  |
| STS                           | k, Rr             | Store Direct to SRAM                                        | (k) ← Rr                                                                                                         | None               | 2       |  |  |  |
| LPM                           | ,                 | Load Program Memory                                         | R0 ← (Z)                                                                                                         | None               | 3       |  |  |  |
| LPM                           | Rd, Z             | Load Program Memory                                         | Rd ← (Z)                                                                                                         | None               | 3       |  |  |  |
| LPM                           | Rd, Z+            | Load Program Memory and Post-Inc                            | Rd ← (Z), Z ← Z+1                                                                                                | None               | 3       |  |  |  |
| SPM                           | Ĺ                 | Store Program Memory                                        | (Z) ← R1:R0                                                                                                      | None               | -       |  |  |  |
| IN                            | Rd, P             | In Port                                                     | Rd ← P                                                                                                           | None               | 1       |  |  |  |
| OUT                           | P, Rr             | Out Port                                                    | P ← Rr                                                                                                           | None               | 1       |  |  |  |
| PUSH                          | Rr                | Push Register on Stack                                      | STACK ← Rr                                                                                                       | None               | 2       |  |  |  |

| Mnemonics                | Operands | Description             | Operation                                | Flags | #Clocks |  |  |
|--------------------------|----------|-------------------------|------------------------------------------|-------|---------|--|--|
| POP                      | Rd       | Pop Register from Stack | Rd ← STACK                               | None  | 2       |  |  |
| MCU CONTROL INSTRUCTIONS |          |                         |                                          |       |         |  |  |
| NOP                      |          | No Operation            |                                          | None  | 1       |  |  |
| SLEEP                    |          | Sleep                   | (see specific descr. for Sleep function) | None  | 1       |  |  |
| WDR                      |          | Watchdog Reset          | (see specific descr. for WDR/timer)      | None  | 1       |  |  |
| BREAK                    |          | Break                   | For On-chip Debug Only                   | None  | N/A     |  |  |

Note: 1. These instructions are only available in ATmega168PA and ATmega328P.

## APPENDIX C - ARDUINO PROTO-SHIELD SCHEMATIC

